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TITLE OF THE INVENTION 

CALLER IDENTIFICATION AND VOICE/DATA SYNCHRONIZATION 
FOR INTERNET TELEPHONY AND RELATED APPLICATIONS 

BACKGROUND OF THE IIWENTION 
Field of the Invention 

The present invention relates to the provision of communications services 
using terminal devices that include computing devices connected to packet- 
switched communications networks. 
Discussion of the Background 

Users of personal computers (PCs) and other general purpose digital 
computing devices have been able to engage in voice communications using these 
devices for many years. One example of software for enabling PC-to-PC 
communication over the Intemet is the SpeakFreely shareware which has been 
available since 1991. More recently, refined commercial grade products have 
emerged such as those offered by VocalTec, Net2Phone, Netspeak, and many 
others. By utilizing the Intemet or other packet switched networks, such products 
have given rise to convergent voice and data solutions as well as created the 
potential for commercial applications in the realm of e-commerce. 

The assignee of the present application, eStara Inc., has addressed some of 
the limitations of these solutions by inventing methods for installing and 
initializing media applications using a "thin client" model. These methods are 
described in U.S. patent application nos, 09/272,139, entitled "PubUc Web Phone 
System," 09/637,805, entitled "Universal Intemet Based Telephony System That 
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Provides Ubiquitous Access For Subscribers From Any Terminal Device," and 

09/ , entitled "Internet Telephony for e-Commerce." The contents of 

each of these applications are hereby incorporated herein by reference. These 
methods and processes created a particular opportunity for enabling end users to 
5 make contact with call centers operated by merchants associated with a web site by 
clicking on icons displayed on web pages. In particular, when such an icon is 
clicked, an Intemet telephony call between the end user (using their terminal as an 
Internet phone) and a call center agent is established without requiring the end user 
to have any Intemet telephony software previously installed on their terminal, all 
1 0 the while allowing the end user to remain on the merchant's web page from which 
the call was initiated. The resulting voice connections link an end user and a call 
center agent who may be using either a telephone or a voice-over-Intemet enabled 
computer device. 

One of the obvious problems in providing voice connections to link PC 
1 5 users to call center agents is providing caller identification in a mixed 

telecommunications environment, where the caller is using an Intemet based or 
packet switched network and the call center agent is equipped with a telephone 
device attached to the public switched telephone network (PSTN) and a computing 
device that provides automated support for order entry, customer service, or other 
20 processes. These call centers use sophisticated call management and customer 
relationship management systems that display key information about the 
customer's history, buying preferences, and purchasing behavior. In order for these 
systems to function, it is necessary to identify the customer making the incoming 



call. As is well known in the art, call centers often use information such as the 
ANI (automatic number identification), DNIS (dialed number identification 
service), or callerlD™ to identify an incoming call. This allows the call center to 
display "screen pops" that enable the call center agent to exploit telephone caller 
5 identification information to pull up customized screens that include scripts for the 
agent. 

When an end user makes an Intemet telephony call to a call center, a PSTN 
gateway is necessarily involved. A PSTN gateway is a device that bridges a call 
from a packet switched network such as the Intemet to a circuit sv^dtched network 

10 such as the PSTN. This scenario creates a problem for the call center because the 
identifying information (ANI, DNIS, or callerlD) received at the call center 
identifies the PSTN gateway rather than the customer. In order to perform the 
screen pop in conventional systems, the call center agent must then ask the 
customer for identifying information (e.g., name, phone number or account 

15 number). This is problematic for two reasons: first, it may be armoying to some 

customers; and second, it takes time to ask for, receive, and key in this information. 

One proposed solution to this problem, described in a European patent 
application filed by Lucent Technologies (EP 0,843,454), is to have the Internet- 
based callers enter information in a dialogue box at the time they initiate a call and 

20 to pass this information through the PSTN using the call setup fields within the 
signaling system. This approach enables the call center systems to provide a 
"screen pop" at the outset of the voice conversation, but it may require redundant 
data entry on the part of a caller who may already be logged into a merchant's call 



site. Thus, this proposed solution solves one of the aforementioned problems (time 
wasted by the call center agent in asking for, receiving, and entering customer 
identification information), but does not address the second problem (customer 
annoyance at having to enter identification information). 
5 What is needed is an automatic method for identifying a customer making 

an Internet telephony call to a call center. 

Another problem common in e-commerce interactions between customers 
or prospects and call center agents is a desire to share text, multimedia, or 
graphical data in addition to the voice interaction. There are a variety of well- 

10 known methods for "pushing" data or for "co-browsing" by two or more web users, 
but all of these methods depend on having a known IP address or universal 
resource locator (URL) for all parties to the interactive session. In the case of a 
mixed telephony environment as described above, an Intemet telephony service 
may not be able to identify which call center computing device is associated with 

1 5 which telephone conversation. This is especially true when calls are distributed by 
an automated call distribution device attached to the public switched network that 
does not communicate with other call center systems (such as customer 
relationship management software). What is needed is a method whereby data can 
be shared between an end user terminal and a call center agent terminal when the 

20 call center agent's terminal data packet network address is not known to the end 

user terminal and the end user terminal's data packet network address is not known 
to the call center agent's terminal. 
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Some call centers do not have automated systems attached to the world 
wide web, but still may wish to "push" web content to callers who are connected to 
the web. What is needed is a simple method for such a party to push web content to 
such callers. 

5 SUMMARY OF THE INVENTION 

The present invention meets the foregoing need to a great extent by 
providing a method and apparatus that provides identification information of an 
end user terminal making an Intemet telephone call to a call center terminal and 
provides a call center agent with the ability to cause an end user terminal making 

10 an Intemet telephone call to display selected web pages and/or to synchronize 

displays between the call center agent and end user terminals. In one embodiment 
of the invention, customer identification information is provided in-band. In 
another embodiment of the invention, customer identification information is 
accomplished out of band, in some cases using an identifier of the PSTN gateway 

15 as an index into a table to identify an end user terminal. In another embodiment, a 
call center agent may enter DTMF (dual tone multi-frequency tones) to push web 
pages to an end user terminal. In still other embodiments, a second 
commxmications link between the end user terminal and the call center agent's 
terminal is established, allowing for data sharing/ synchronization. 
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BRIEF DESCRIPTION OF THE DRAWINGS 

A more complete appreciation of the invention and many of the attendant 
advantages and features thereof will be readily obtained as the same becomes better 
understood by reference to the following detailed description when considered in 
5 connection with the accompanying drawings, wherein: 

FIG. 1 is a block diagram illustrating an exemplary communication system 
according to one embodiment of the present invention. 

FIG. 2 is a block diagram illustrating an exemplary communication system 
according to a second embodiment of the present invention. 
10 FIG. 3 is a block diagram illustrating an exemplary communication system 

according to a third embodiment of the present invention. 

FIG. 4 is a sequence diagram illustrating steps involved in establishing 
communications through a chatroom according to the embodiment of Figure 3. 



DESCRIPTION OF PREFERRED EMBODIMENTS 

1 5 The present invention v^ll be discussed with reference to preferred 

embodiments of Internet telephony identification/synchronization applications. 
Specific details, such as steps in establishing the Internet telephone call and 
information included with icons, are set forth in order to provide a thorough 
understanding of the present invention. The preferred embodiments discussed 

20 herein should not be understood to limit the invention. Furthermore, for ease of 
understanding, certain method steps are delineated as separate steps; however, 
these steps should not be construed as necessarily distinct nor order dependent in 
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their performance. Still further, devices (such as servers) described herein as 
separate entities may be implemented on separate physical devices and/or as 
separate processes running on a single physical device. 

Before proceeding further, it is necessary to describe various configurations 
5 and equipment that may be involved in an Intemet telephone call. Referring now 
to the drawings, wherein like reference numerals designate identical or 
corresponding parts throughout the several views, Figure 1 illustrates a 
communications systems 100 including a data packet network 110 such as the 
Intemet. Connected to the data packet network 1 10 are end user terminals 120a,b. 

10 End user terminal 120a is directly connected to the data packet network 110, while 
end user terminal 120b is cormected to the data packet network 1 10 through the 
PSTN (public switched telephone network) 171 using a typical dial-up connection 
via a modem to an Intemet service provider (not shown in Figure 1). For the 
purposes of the present invention, either type of connection may be used. Each of 

1 5 the terminals 120 includes a web browser 122. 

An end user at the terminal 120 may view web pages from a variety of 
sources using web browser 122 (not shovm in terminal 120b solely for the sake of 
convenience), including merchant web servers 140,142 which are also connected to 
the data packet network 110. Each of the merchant web servers 140, 142 includes 

20 an icon for establishing a VoIP telephone call to an associated call center. In 

preferred embodiments, the icon will include an address for an application server 
190. Preferably, the icon will also include icon identification information, which 
may include one or more of the following: a session ID (an identifier of a browsing 
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"session" which is assigned by the server being browsed), a customer ID (an 
identifier of the end user doing the browsing), a link ID (an identifier of the icon 
clicked on by the end user), or a telephone number associated with a call center. 

When the end user at the terminal 120 clicks on the icon, a message is sent 
5 to the application server 190. In response, the application server 190 sends a 
delivery applet 124 to the end user terminal 120. The delivery applet will then 
determine whether a media applet 126 is present and, if not, will obtain a media 
applet from the application server 190 (alternatively, the media applet 126 may be 
automatically sent with, or included in, the delivery applet 124). The media applet 

10 126 controls the low level operation (e.g., digitizing and packeting analog voice 
samples) of an Intemet telephone call. Next, the delivery applet 124 sends a 
message to a call server 180 to inform the call server 180 that an Intemet telephony 
call to a call center is desired. 

When the icon is provided by the merchant web server 141, a "pure" 

15 Intemet telephony call between the respective end user terminal 120 and a VoIP- 
ready call center 150 associated with the merchant web server 141 (as indicated by 
dashed line 142) is desired. In a pure VoIP call, packets are exchanged between 
the respective end user terminal 120 and the call center 150 directly through the 
data packet network 110 without using the PSTN. When the icon is provided by 

20 merchant web server 143, the VoIP telephone call must be routed through a 

gateway 160 and the PSTN 172 to a conventional call center 1 80, which is not 
VoIP-ready, associated with the merchant web server 143 as indicated by the 
dashed line 144. Such an Intemet telephone call between an end user terminal 
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connected to the Internet and a call center connected to the PSTN shall be referred 
to herein as a mixed Internet telephone call. 

The identification of the desired call center (which also determines whether 
the call will be a pure Internet telephone call or a mixed Internet telephone call) 
5 may be made in a variety of ways. In some embodiments, the icon identification 
information includes a phone number, which in and of itself identifies the call 
center. In other embodiments, a merchant ID, a link ID, or a combination of the 
two, are used as an index into a table maintained at the call server 192 to identify 
the desired call center. Other methods for determining the desired call center, 
10 including more sophisticated methods which rely on factors other than information 
included in the icon, such as time of day and geography, are also possible. 

If the desired call center corresponds to a VoIP -ready call center 150, the 
call server 1 92 sets up the call by contacting the call center 1 50, informing it that a 
call is desired, and exchanging voice packet addresses between the media applet 
15 1 26 at the end user terminal 120. Once the call has been set up, the media 

application 126 exchanges voice packets with an address at the call center 150. 

If the desired call center corresponds to a PSTN call center 180, the call 
server 192 informs the gateway 160 to connect to the call center 180 via the PSTN 
172. The call server then sets up an exchange of packets between the media applet 
20 126 at the terminal 120 and the gateway 160. In this situation, a packet is sent 

from the terminal 120 to the gateway 160. The gateway 160 unpacks the packet, 
converts the digital information into analog form, and transmits it to the call center 
180 over the PSTN 172 (PSTN 171 and PSTN 172 may be part of the same public 



switched telephone network, but are shown separately in Figure 1 for the pxirposes 
of illustration). The gateway also receives voice information in analog form from 
the PSTN call center 180, digitizes and packetizes the analog information, and 
sends the packets to the appropriate end user terminal 120. 

5 CALLER IDENTIFICATION AT THE CALL CENTER 

It will be apparent to those of skill in the art that, in the situation described 
above in connection with the call to the PSTN call center 1 80, the identity of the 
end user at the terminal 120 is not knovm to the call center at the start of the call. 
In order to overcome this problem, several strategies are available. These 

10 strategies may be divided into two types: in-band signaling and out-of-band 

signaling. In-band signaling refers to providing identification data in the same 
frequency band as voice data (that is, as an audible signal), while out-of-band 
signaling refers to providing identification data in another marmer. 

In some in-band embodiments, customer identification information is 

15 encoded in the telephone call by the call server 192. The customer identification 
may come from a variety of sources. For example, some or all of the icon 
identification information (e.g., the customer ID, session ID), which is inserted in 
the icon by the merchant web server 141, is used as the customer identification 
information in some embodiments. Altematively, the media applet 126 and/or 

20 delivery applet 124 searches the hard drive at the terminal 120 to gather cookies or 
other information that identifies the customer. The media applet 126 and/or the 
delivery applet 124 transmit the customer identification information to the gateway 
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160 (either directly or through the call server 192). Once received at the gateway 
160, the customer identification information is used to replace the ANI delivered to 
the call center 180. In other embodiments, the same information is encoded into 
other fields, such as Signaling System 7 fields, associated w^ith the telephone call 
5 instead of replacing the ANI. In still other embodiments, the desired identification 
data is transmitted at the start of a phone call in a manner similar to that of a 
facsimile machine (i.e., it is transmitted in the same manner as voice information in 
the phone call). Other variations on this theme are also possible. (In a pure 
Internet telephony call to a VoIP call center 150, the same types of customer 

10 identification information can be included in the packets sent from the terminal 120 
to call center 150.) The information added in this process is then detected and 
passed to a customer relationship management system at the call center agent's 
station to perform the screen pop. In this maimer, the screen pop is performed at 
the start of the call w^ithout requiring the end user to manually type their customer 

1 5 identification information, thereby saving time and aggravation. 

In the foregoing embodiments, the customer identification information is 
passed to the gateway 160 for inclusion into the telephone call. In alternative 
embodiments, the customer identification information is converted to an audible 
signal such as a DTMF tone, encoded into data packets at the end user terminal 

20 120, and transmitted through the gateway 1 60 to the call center 1 80 in the same 
maimer as voice data packets. (The packets may be preformed - that is, digitized 
data corresponding to individual numbers and symbols on a telephone dialpad may 
be included with the media applet 126 or the delivery applet 124 such that 

-11- 



combinations of the digitized data may be combined to fomi one or more packets 
for a desired command). The packets are received at the gateway 160, converted 
into an analog signal and transmitted to the call center 1 80 over the PSTN. The 
call center 180 then detects the presence of the tones, converts the tones into 
5 corresponding customer identification information and uses the information to 
perform the screen pop as described above. One feature of this method is that it 
does not require a specially modified gateway. 

In one out-of-band strategy, the call center 1 80 recognizes that an incoming 
call originates from a telephone because the ANI (or DNIS or caller ID) 

10 corresponds to a PSTN gateway 160. A customer relationship management (CRM) 
system computer 1 82 at the call center 1 80 then queries a database maintained by 
the call server 192 or gateway 160 to correlate an incoming call to a particular 
customer. For example, in one embodiment the CRM computer 1 82 sends a 
message to the call server 192 that includes the ANI associated with the received 

15 call. The call server 192, which stores customer identification information 

received from the terminal 120, then determines the last call it instructed the 
gateway 160 associated with the ANI to set up, retrieves the appropriate customer 
identification information, and sends it to the call center 180. 

Alternatively, the gateway 160 may be configured to include different ANIs 

20 in each phone call and report this information to the call server 192 for each call 
the call server 192 commands the -gateway 160 to place. The call server 192 
maintains a table of ANI/customer information pairings so that when it receives an 
inquiry for an ANI from the CRM computer 182, it simply uses the ANI as an 
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index into the table to retrieve the corresponding customer information and passes 
it along to the CRM computer 182. 

Another out-of-band embodiment is illustrated in Figure 2. The system 200 
is similar to the system 100 of Figure 1, except that an integration server 194 has 
5 been added. A call from the terminal 120 to the PSTN call center 1 80 is initiated 
when the end user clicks on an icon at the merchant web server 143 in the same 
manner as described above. When the terminal 120 is informed by the call server 
1 92 of the port at the gateway 1 60 to which voice packets are to be sent, the 
terminal 120 also sends a message to an integration server 194 that includes some 

10 or all of the customer identification information and the associated port number. 

The process then continues as described above until the PSTN gateway 160 places 
the call to the call center 180. The call center 180 then obtains the ANI for the 
phone call and does a table lookup, using the ANI as an index, that reveals the ANI 
is associated with the gateway 160. The call center 1 80 then passes the ANI to the 

15 integration server 192. The integration server 192 uses the ANI to determine with 
which port number of the gateway 160 the call is associated. Each port (to which 
packets are sent by the media application 126) on the gateway 160 is mapped to a 
single ANI. Once the port number of PSTN gateway 1060 is received, the 
integration server 1 94 simply uses it as an index to retrieve the customer 

20 identification information. This customer identification information is then sent to 
the call center CRM system 182 for use by the call center 120. In some "pure" 
Internet telephony embodiments, the integration server 192 functions in a manner 
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similar to that described above, with an pseudo-ANI being supplied by the terminal 
120. 

CONTROL/SYNCHRONIZATION 

It is also possible for an agent at a call center to control the display of web 
5 pages at the terminal 120. Providing this ability to the call center agent is especially 
useful because it can allow a call center agent to synchronize an end user's display 
with a display at a terminal used by the agent. However, this ability is also useful 
even where the call center agent does not have a terminal. 

Li one embodiment, the customer service representative enters a dialpad 

10 sequence (e.g., *76) on his telephone. The dialpad sequence is detected by the 

PSTN gateway 160 and interpreted as a display command. The PSTN gateway 160 
strips the dialpad sequence out of the audio information (so that it is not heard by 
the end user) that is to be packetized and passes the dialpad sequence to the call 
server 192. The call center 192 either passes the dialpad sequence directly to the 

15 delivery applet 124, or uses the dialpad sequence (or some portion thereof) as an 
index to retrieve a URL which is sent to the delivery applet 124. The delivery 
applet 124 then sends this information (the "76" or the URL) to the web server 143 
in a download () message, which causes the web server 143 to send the 
corresponding web page to the end user terminal 120. 

20 In those embodiments in which the dialpad sequence is used by the call 

server 192 as an index to retrieve a URL, the call server 192 is required to maintain 
a table of URLs, which must of course be supplied and updated by the merchant. 
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Thus, it may be preferable to simply pass the dialpad sequence to the merchant 
server, which itself can use the sequence as an index to determine which page to 
download. 

In the embodiment described above, the dialpad sequence is detected at the 
5 gateway 160. In an altemative embodiment, the dialpad sequence is digitized and 
included in voice packets sent to the terminal 120, where it is detected and sent to 
the web server 143 in a download () message or used to retrieve a URL which is 
sent to the web server 143 in a download message as previously described. There 
are advantages and disadvantages associated with both methods. Detecting the 

10 dialpad sequence at the gateway 160 requires that a standard gateway be modified 
to detect the dialpad sequence, strip it out, and send it to terminal 120. However, 
detecting the dialpad sequence at the gateway 160 rather than at the terminal 120 
avoids the problems associated with missing portions of the dialpad sequence due 
to packet loss an/or inaccuracies that can be caused by variations in compression 

15 technologies on the packet switched (i.e., the Intemet) and circuit switched (i.e., 
PSTN) networks. 

Yet another strategy for controlling a display at the terminal 120 and/or 
synchronizing displays at the terminal 120 and an agent terminal at the call center 
180 is illustrated by the system 300 of Figure 3 and the sequence diagram 400 of 
20 Figure 4. In this embodiment, an agent at the call center 180 begins each work day 
by starting a web browser at step 305 and logging on to a chat server 196 at step 
410. When the agent logs on, the chat server 196 retums a chatroom ID, which is 
preferably a short (e.g., 2-4 digit) numeric code, at step 420. In preferred 
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embodiments, this chatroom ID corresponds to one of a number of chatrooms 
hosted on the integration server 194. The foregoing preferably occurs before any 
calls are handled by the agent. 

Next, an end user viewing a web page from merchant web server 143 clicks 
5 on an Intemet telephony icon at step 430. This initiates a call to call center 1 80 at 
step 440. When the call is routed through an ACD (automatic call distributor) at 
the call center to the particular agent at step 450, the agent keys in the chatroom ID 
using the telephone handset at step 460. This causes DTMF signals to be 
transmitted to the media application 126. (In altemative embodiments, the DTMF 

10 signals are detected at the gateway 160 and translated into a message which is sent 
to the terminal 120.) The media application 126 recognizes the DTMF signals as a 
chatroom ID and opens a new browser window at step 470. Next, the digits 
represented by the signals are appended to a predetermined URL portion (e.g., the 
predetermined URL portion forms the first part of the URL and the chatroom ID is 

1 5 appended as "/xx" where "xx" is a two digit chatroom ID) to form a chatroom URL 
and the newly-opened web browser window is directed to the corresponding 
chatroom at step 480. The agent, who also knows the address of the chatroom 
based on the code he entered, may then send information to the caller through the 
chatroom on the integration server 194 at steps 491-494, and the caller may send 

20 information to the agent at steps 495-498. This information may comprise standard 
chat messages. This information may also include web push information - that is, 
commands including URLs that cause the terminal to request web pages 
corresponding to the URLs to be downloaded in the manner described above. 
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The foregoing technique has several advantages over other techniques. 
First, the technique requires no changes to existing call centers (unlike the 
embodiment described above, wherein the call center must be modified to 
recognize the PSTN gateway ANI and perform special processing in response 
5 thereto). Second, the method is more reliable than methods that rely on the ANI 
because ANI numbers are sometimes lost when a call crosses phone network 
boundaries. It should also be recognized that the foregoing technique is not limited 
to exchanging chatroom messages and/or facilitating web pushes. Any kind of 
information may be exchanged. For exeunple, this technique could be used to set 

10 up a channel to allow the terminal 120 to send cookie information, or other 
information that identifies the caller, to the agent. 

It is not necessary to utilize a chatroom to facilitate communications 
between the end user and the agent. As an alternative to such embodiments, in 
which a chatroom hosted on an intermediate computer is used to synchronize the 

15 displays of the parties to the call, a direct communications channel such as an SSL 
socket could be established between the end user and agent terminals. For 
example, the DTMF signals (whether detected at the gateway and sent to the end 
user computer by the gateway through the data packet network or detected at the 
end user computer itself from decoded voice packets received fi-om the gateway) 

20 could form a portion of a URL for a computer associated with the agent to which a 
socket request is sent. In this case, modifications to the customer call center may 
be necessary to make the association between the DTMF code entered by the agent 
and the URL. One simple way this can be achieved is by permanently assigning 

-17- 



each agent terminal to one of the channels corresponding to the DTMF code. The 
agent, upon receiving a call, simply enters the DTMF code associated with the 
terminal he or she is using. Upon detection/receipt of the DTMF code, the end user 
terminal 120 sends a socket request to the URL formed in part by the DTMF code, 
5 which corresponds to the agent terminal. 

In one simple, non-limiting example, a call center has agent stations 
(comprising a telephone extension connected to the PSTN and a PC connected to 
the Internet) for forty agents. Each of the agent PCs is assigned a URL with the 
same prefix, but ending with an "xx", where the "xx" represents a number from 

1 0 one to forty. One number is assigned to each of the PCs. This nimiber is made 
known to the agents (such as by simply pasting a label with the "xx" number on 
each monitor). When a call is received, the agent keys in the "xx" number on the 
telephone keypad. When the DTMF tones are detected, the end user computer, 
which has knowledge of the prefix, appends the "xx" code corresponding to the 

1 5 DTMF tones to the prefix and directs a communication such as a socket request to 
the URL formed by the prefix and "xx" code. It will be readily understood that the 
foregoing is an extremely simple example and that this technique is not so 
limited. 

Controlling the end user's display in a pure Intemet telephony embodiment 
20 may be performed in a simpler (relative to the above-described methods), more 

direct manner. For example, referring now back to Figure 2, when a call is made to 
the VoIP -ready call center 150, a CRM system therein sends a display code (not 
necessarily a dialpad sequence) to the terminal 120 (possibly through the call 
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server 192 or the integration server 194). When the display code is received at the 
terminal 1 20, it is included in a download () message sent to the merchant web 
server 141. The web page corresponding to the display code is then displayed at 
the terminal 120. Of course, more direct routes are also possible, especially where 
5 the web server 143 is in communication with the CRM system at the call center 
150. 

It will be appreciated by those of skill in the art that the functions 
performed by the application server 190, the call server 192, the integration server 
194, the chat server 196, and/or the gateway 160 may be performed by a single 
10 physical device as a single process or as one or more separate processes, or may be 
performed in separate physical devices. 

It should be understood that, although the preferred embodiments discussed 
herein are particularly useful in the realm of e-commerce, they have broader 
application. For example, he techniques discussed herein can be applied to general 
15 purpose Intemet telephony applications, to Internet telephony conference call 
applications, as well as many other applications. 

Obviously, numerous modifications and variations of the present invention 
are possible in light of the above teachings. It is therefore to be understood that 
within the scope of the appended claims, the invention may be practiced otherwise 
20 than as specifically described herein. 
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